Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add training service #225

Merged
merged 13 commits into from
Jan 16, 2025
Merged

Add training service #225

merged 13 commits into from
Jan 16, 2025

Conversation

thodkatz
Copy link
Collaborator

@thodkatz thodkatz commented Dec 9, 2024

An initial implementation of adding neural network training in tiktorch :P

It requires:

The package pytorch-3dunet is used as our framework to configure the models.

Supported workflows:

  • Start
  • Pause
  • Resume
  • Shutown
  • Get training state
  • Recover if training failed

The above are demonstrated with tests. Please check them first :)

For thread synchronization we rely on a thread-safe priority queue (todo: explain the scheme with the concept of ICommand, and the error handling).

Manual testing

I have created a setup to test the server with actual data. You can find more here: https://github.com/thodkatz/ilastik-playground

@thodkatz thodkatz force-pushed the add-training-servicer branch from bbf0243 to ace0793 Compare December 9, 2024 16:35
Copy link

codecov bot commented Dec 9, 2024

Codecov Report

Attention: Patch coverage is 66.79438% with 260 lines in your changes missing coverage. Please review.

Project coverage is 64.48%. Comparing base (5ea5d3a) to head (c699344).
Report is 14 commits behind head on main.

Files with missing lines Patch % Lines
tiktorch/proto/training_pb2_grpc.py 55.14% 48 Missing ⚠️
tiktorch/trainer.py 65.48% 39 Missing ⚠️
tiktorch/server/session/backend/supervisor.py 75.51% 36 Missing ⚠️
tiktorch/proto/training_pb2.py 27.02% 27 Missing ⚠️
tiktorch/proto/inference_pb2.py 16.12% 26 Missing ⚠️
tiktorch/proto/utils_pb2.py 37.50% 15 Missing ⚠️
tiktorch/server/session/process.py 66.66% 14 Missing ⚠️
tiktorch/server/session/backend/commands.py 82.66% 13 Missing ⚠️
tiktorch/server/session/backend/base.py 71.42% 12 Missing ⚠️
tiktorch/server/grpc/training_servicer.py 87.01% 10 Missing ⚠️
... and 5 more
Additional details and impacted files
@@            Coverage Diff             @@
##             main     #225      +/-   ##
==========================================
- Coverage   64.60%   64.48%   -0.12%     
==========================================
  Files          40       47       +7     
  Lines        2195     2689     +494     
==========================================
+ Hits         1418     1734     +316     
- Misses        777      955     +178     

☔ View full report in Codecov by Sentry.
📢 Have feedback on the report? Share it here.

@thodkatz thodkatz force-pushed the add-training-servicer branch from ace0793 to cbb2619 Compare December 9, 2024 16:42
@@ -1,7 +1,7 @@
[pytest]
python_files = test_*.py
addopts =
--timeout 10
--timeout 60
Copy link
Collaborator Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The difference in creating threads, processes using a start method "spawn" instead of "fork" is quite significant, that led me to bump it, so the tests can pass for macos and windows platforms.

@thodkatz thodkatz force-pushed the add-training-servicer branch 3 times, most recently from e9fc4b0 to f345f69 Compare December 10, 2024 13:30
@thodkatz thodkatz force-pushed the add-training-servicer branch 3 times, most recently from 750ee88 to d432e25 Compare December 11, 2024 15:23
- Supported operations: start, resume, pause, shutdown
- pytorch-3dunet package is used as the framework to create the models
… failed

I caught an edge case, where events are blocked, because we have exited the training, and the tasks of the queue would remain unprocessed.
Creating and closing processes and threads can be quite time consuming
resulting to test timeouts if the tests performs a lot of actions.
Applying monkeypatch to a parent process won't propagated to a child process if the start method is spawn (macos) instead of fork (linux)
- To fix test on windows, convert label data to float64
The should stop callbacks are boolean, so we need to aggregate their return value. Previously the return value wasn't taken into account, and the callbacks were returning none
The enum is used for validation check before triggering one of them. Previously I was checking if the queue was alive, but that won't be enough, for example if you want to perform resume, while you are resumed, the queue is operational, but the action shouldn't be valid.
@thodkatz thodkatz force-pushed the add-training-servicer branch 6 times, most recently from b9153b1 to a088627 Compare December 19, 2024 10:00
@thodkatz thodkatz force-pushed the add-training-servicer branch 3 times, most recently from 09fcb85 to 4a5ed85 Compare December 20, 2024 15:37
@thodkatz thodkatz force-pushed the add-training-servicer branch 2 times, most recently from 52fb50f to 752cb59 Compare December 20, 2024 20:14
Move NamedInt and Tensor proto to a separate file so training proto can
use as well
- The inference servicer had a procedure to list the available devices.
  This is needed or the training servicer as well. So list devices is
  decoupled to be shared.
@thodkatz thodkatz force-pushed the add-training-servicer branch from 752cb59 to 27b3923 Compare December 20, 2024 20:48
Copy link
Collaborator

@k-dominik k-dominik left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Hey @thodkatz, this is exciting! Also thank you for being available in DMs/calls for some questions. After looking at the proposed changes I have to say that you followed the original design through the whole onion nicely.

The tests look also pretty thorough and instill confidence, especially given that we target linux, mac, and windows platforms.

Seeing how little you had to adapt the pytorch-3dunet trainer class gives me confidence, that it was a good decision to go for it.

--> LGTM

@thodkatz
Copy link
Collaborator Author

Hey @k-dominik ! Thanks a lot for the kind words :) It is true that the onion kind of structure needs to be revised and simplified, totally agree with that.

I hope the tests will help with the refactoring part.

Of course, I am always available :)

@thodkatz thodkatz merged commit 57df547 into ilastik:main Jan 16, 2025
8 checks passed
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants